package karaoke.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collection;

import karaoke.dao.BaseDAO;
import karaoke.excepcion.DAOExcepcion;
import karaoke.modelo.Persona;
import karaoke.modelo.Usuario;
import karaoke.util.ConexionBD;

public class PersonaDAO extends BaseDAO{

	public Persona insertar(Usuario objUsuario ) throws DAOExcepcion {
			
		String query = "insert into persona(nomPersona,appPersona,apmPersona,docidPersona,tipoPerfil,idUsuario,telefono,celular) values (?,?,?,?,?,?,?,?)";
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setString(1, objUsuario.getNombre());
			stmt.setString(2, objUsuario.getAppaterno());
			stmt.setString(3, objUsuario.getApmaterno());
			stmt.setString(4, objUsuario.getDocumentoid());
			stmt.setString(5, objUsuario.getPerfil());
			stmt.setInt(6, objUsuario.getIdUsuario());
			stmt.setString(7, objUsuario.getTelefono());
			stmt.setString(8, objUsuario.getcelular());
			
			int i = stmt.executeUpdate();
			if (i != 1) { 
				throw new SQLException("No se pudo insertar");
			}		
			
			int id = 0;
			query = "select last_insert_id()";
			stmt = con.prepareStatement(query);
			rs = stmt.executeQuery();
			if (rs.next()) {
				id = rs.getInt(1);
			}
			objUsuario.setcodpersona(id);

		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		return objUsuario;
	}

	
}
